home *** CD-ROM | disk | FTP | other *** search
/ Developer CD Series 1994 November: Tool Chest / Dev.CD Nov 94.toast / New System Software Extensions / OpenDoc A6 / OpenDoc Parts Framework / OPF / Found / BCCollec / Structs / Sets / BCSetD.h < prev    next >
Encoding:
Text File  |  1994-04-21  |  2.1 KB  |  68 lines  |  [TEXT/MPS ]

  1. //  The C++ Booch Components (Version 2.1)
  2. //  (C) Copyright 1990-1993 Grady Booch. All Rights Reserved.
  3. //
  4. //  BCSetD.h
  5. //
  6. //  This file contains the declaration of the dynamic set.
  7.  
  8. #ifndef BCSETD_H
  9. #define BCSETD_H 1
  10.  
  11. #include "BCNodes.h"
  12. #include "BCDynami.h"
  13. #include "BCHashTa.h"
  14. #include "BCSet.h"
  15.  
  16. // Dynamic set
  17.  
  18. template<class Item, BC_Index Buckets, class StorageManager>
  19. class BC_TDynamicSet : public BC_TSet<Item> {
  20. public:
  21.  
  22.   BC_TDynamicSet();
  23.   BC_TDynamicSet(BC_Index (*)(const Item&));
  24.   BC_TDynamicSet(BC_Index chunkSize);
  25.   BC_TDynamicSet(const BC_TDynamicSet<Item, Buckets, StorageManager>&);
  26.   virtual ~BC_TDynamicSet();
  27.  
  28.   virtual BC_TSet<Item>& operator=(const BC_TSet<Item>&);
  29.   virtual BC_TSet<Item>& operator=(const BC_TDynamicSet<Item, Buckets, StorageManager>&);
  30.   virtual BC_Boolean operator==(const BC_TSet<Item>&) const;
  31.   virtual BC_Boolean
  32.     operator==(const BC_TDynamicSet<Item, Buckets, StorageManager>&) const;
  33.   BC_Boolean operator!=(const BC_TDynamicSet<Item, Buckets, StorageManager>&) const;
  34.  
  35.   virtual void SetHashFunction(BC_Index (*)(const Item&));
  36.   virtual void SetChunkSize(BC_Index chunkSize);
  37.   virtual void Preallocate(BC_Index new_length);
  38.   virtual void Clear();
  39.   virtual BC_Boolean Add(const Item&);
  40.   virtual BC_Boolean Remove(const Item& at);
  41.  
  42.   virtual BC_Index ChunkSize() const;
  43.   virtual BC_Index Extent() const;
  44.   virtual BC_Boolean IsEmpty() const;
  45.   virtual BC_Boolean IsMember(const Item&) const;
  46.   
  47.   static void* operator new(size_t);
  48.   static void operator delete(void*, size_t);
  49.  
  50. protected:
  51.  
  52.   BC_TTable<Item, BC_Boolean, Buckets,
  53.             BC_TDynamic<BC_TPair<Item, BC_Boolean>, StorageManager> > fRep;
  54.  
  55.   virtual void Purge();
  56.   virtual BC_Boolean Attach(const Item&, const BC_Boolean&);
  57.   virtual BC_Boolean Attach(const Item&);
  58.   virtual BC_Boolean Detach(const Item&);
  59.   virtual BC_Index Cardinality() const;
  60.   virtual BC_Index NumberOfBuckets() const;
  61.   virtual BC_Index Length(BC_Index bucket) const;
  62.   virtual BC_Boolean Exists(const Item&) const;
  63.   virtual const Item& ItemAt(BC_Index bucket, BC_Index index) const;
  64.   
  65. };
  66.  
  67. #endif
  68.